colorchooser: Do less in ::response
authorMatthias Clasen <mclasen@redhat.com>
Thu, 8 Mar 2012 02:42:28 +0000 (21:42 -0500)
committerMatthias Clasen <mclasen@redhat.com>
Thu, 8 Mar 2012 02:42:28 +0000 (21:42 -0500)
Some people destroy their widgets in ::response, so trying
to access dialog internals from the class handler that is
running afterwards has the potential to cause problems.
Instead, we can reset the ::show-editor property every
time we map the dialog.

gtk/gtkcolorchooserdialog.c

index 7877225bcd0b88212e145b64dec2d846a35b57ce..177224ec741d3755d31b006a4c6050c637e81a66 100644 (file)
@@ -147,9 +147,18 @@ gtk_color_chooser_dialog_response (GtkDialog *dialog,
       gtk_color_chooser_get_rgba (GTK_COLOR_CHOOSER (dialog), &color);
       gtk_color_chooser_set_rgba (GTK_COLOR_CHOOSER (dialog), &color);
     }
+}
 
-  g_object_set (GTK_COLOR_CHOOSER_DIALOG (dialog)->priv->chooser,
+static void
+gtk_color_chooser_dialog_map (GtkWidget *widget)
+{
+  /* We never want the dialog to come up with the editor,
+   * even if it was showing the editor the last time it was used.
+   */
+  g_object_set (GTK_COLOR_CHOOSER_DIALOG (widget)->priv->chooser,
                 "show-editor", FALSE, NULL);
+
+  GTK_WIDGET_CLASS (gtk_color_chooser_dialog_parent_class)->map (widget);
 }
 
 static void
@@ -219,11 +228,14 @@ static void
 gtk_color_chooser_dialog_class_init (GtkColorChooserDialogClass *class)
 {
   GObjectClass *object_class = G_OBJECT_CLASS (class);
+  GtkWidgetClass *widget_class = GTK_WIDGET_CLASS (class);
   GtkDialogClass *dialog_class = GTK_DIALOG_CLASS (class);
 
   object_class->get_property = gtk_color_chooser_dialog_get_property;
   object_class->set_property = gtk_color_chooser_dialog_set_property;
 
+  widget_class->map = gtk_color_chooser_dialog_map;
+
   dialog_class->response = gtk_color_chooser_dialog_response;
 
   g_object_class_override_property (object_class, PROP_RGBA, "rgba");